Cancelled
Push — release/2.1.0 ( 9888ea )
by Kevin Van
09:55 queued 09:52
created

MetaMatches   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 119
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 104
dl 0
loc 119
rs 10
c 0
b 0
f 0
wmc 5

4 Functions

Rating   Name   Duplication   Size   Complexity  
A componentDidMount 0 3 1
A updateData 0 19 1
A componentWillUnmount 0 3 1
B render 0 73 2
1
import React, { Component, Fragment } from "react"
2
import { graphql, StaticQuery } from "gatsby"
3
// import './meta-matches.scss'
4
import MatchWithLogo from "./match-with-logo"
5
import MiniRanking from "./mini-ranking"
6
7
class MetaMatches extends Component {
8
  constructor(props) {
9
    super(props)
10
11
    this.state = {
12
      data: [],
13
      globalRanking: [],
14
      loading1: true,
15
      loading2: true,
16
    }
17
18
    this.uuid = props.division.toLowerCase()
19
20
    this.apiServerUrl = props.config.site.siteMetadata.serverUrl
21
    this.apiRefreshRate = props.config.site.siteMetadata.refreshRate
22
    this.timeout = {}
23
  }
24
25
  updateData() {
26
    const { season, region, division, regnumber } = this.props
27
28
    fetch(
29
      `${this.apiServerUrl}/meta/${season}/${region}/${division}/${regnumber}`
30
    )
31
      .then((response) => response.json())
32
      .then((json) => this.setState({ data: json, loading1: false }))
33
34
    fetch(
35
      `${this.apiServerUrl}/seasons/${season}/regions/${region}/rankings/${division}`
36
    )
37
      .then((response) => response.json())
38
      .then((json) => this.setState({ globalRanking: json, loading2: false }))
39
40
    this.timeout = setTimeout(() => {
41
      this.updateData(() => {})
42
    }, this.apiRefreshRate)
43
  }
44
45
  componentDidMount() {
46
    this.updateData()
47
  }
48
49
  componentWillUnmount() {
50
    clearInterval(this.timeout)
51
  }
52
53
  render() {
54
    if (
55
      this.state.loading1 === false &&
56
      this.state.loading2 === false &&
57
      this.state.data
58
    ) {
59
      const { next, previous, ranking } = this.state.data
60
      return (
61
        <Fragment>
62
          <ul className="widget__filter" data-tabs id={`matches-${this.uuid}`}>
63
            <li className="tabs-title">
64
              <a href={`#matches-${this.uuid}-prev`}>Vorige</a>
65
            </li>
66
            <li className="tabs-title is-active">
67
              <a href={`#matches-${this.uuid}-next`}>Volgende</a>
68
            </li>
69
            <li className="tabs-title">
70
              <a href={`#matches-${this.uuid}-rank`}>Ranking</a>
71
            </li>
72
          </ul>
73
          <div data-tabs-content={`matches-${this.uuid}`}>
74
            <div className="tabs-panel" id={`matches-${this.uuid}-prev`}>
75
              {previous && (
76
                <MatchWithLogo match={previous.match} lazyload={true} />
77
              )}
78
              {previous && (
79
                <MiniRanking ranking={[previous.opponent.ranking, ranking]} />
80
              )}
81
82
              {!previous && <div className="matches_overview__wrapper">Geen vorige wedstrijden gevonden</div>}
83
            </div>
84
            <div
85
              className="tabs-panel is-active"
86
              id={`matches-${this.uuid}-next`}
87
            >
88
              {next && <MatchWithLogo match={next.match} lazyload={true} />}
89
              {next && (
90
                <MiniRanking ranking={[next.opponent.ranking, ranking]} />
91
              )}
92
              {!next && <div className="matches_overview__wrapper">Geen volgende wedstrijden gevonden</div>}
93
            </div>
94
            <div className="tabs-panel" id={`matches-${this.uuid}-rank`}>
95
              <MiniRanking ranking={this.state.globalRanking} />
96
            </div>
97
          </div>
98
        </Fragment>
99
      )
100
    } else {
101
      return (
102
        <Fragment>
103
          <ul className="widget__filter" data-tabs id={`matches-${this.uuid}`}>
104
            <li className="tabs-title">
105
              <a href={`#matches-${this.uuid}-prev`}>Vorige</a>
106
            </li>
107
            <li className="tabs-title is-active">
108
              <a href={`#matches-${this.uuid}-next`}>Volgende</a>
109
            </li>
110
            <li className="tabs-title">
111
              <a href={`#matches-${this.uuid}-rank`}>Ranking</a>
112
            </li>
113
          </ul>
114
          <div data-tabs-content={`matches-${this.uuid}`}>
115
            <div className="tabs-panel" id={`matches-${this.uuid}-prev`} />
116
            <div
117
              className="tabs-panel is-active"
118
              id={`matches-${this.uuid}-next`}
119
            >
120
              Nog geen wedstrijden gekend
121
            </div>
122
            <div className="tabs-panel" id={`matches-${this.uuid}-rank`} />
123
          </div>
124
        </Fragment>
125
      )
126
    }
127
  }
128
}
129
130
const query = graphql`
131
  query {
132
    site {
133
      siteMetadata {
134
        serverUrl
135
        refreshRate
136
      }
137
    }
138
  }
139
`
140
141
export default ({ season, region, division, regnumber }) => (
142
  <StaticQuery
143
    query={query}
144
    render={(data) => (
145
      <MetaMatches
146
        config={data}
147
        season={season}
148
        region={region}
149
        division={division}
150
        regnumber={regnumber}
151
      />
152
    )}
153
  />
154
)
155